package swb.api.com.repository;

import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
import swb.api.com.repository.dto.SysUserRole;

import java.util.List;

@Repository
public interface SysUserRoleRepository extends JpaRepository<SysUserRole, Long> {

    /**
     * 根据用户ID查找用户角色关联记录
     * @param userId 用户ID
     * @return 用户角色关联列表
     */
    @Query("SELECT ur FROM SysUserRole ur WHERE ur.userId = :userId")
    List<SysUserRole> findByUserId(@Param("userId") Long userId);

    /**
     * 根据角色ID查找用户角色关联记录
     * @param roleId 角色ID
     * @return 用户角色关联列表
     */
    @Query("SELECT ur FROM SysUserRole ur WHERE ur.roleId = :roleId")
    List<SysUserRole> findByRoleId(@Param("roleId") Long roleId);

    /**
     * 根据用户ID删除用户角色关联记录
     * @param userId 用户ID
     */
    void deleteByUserId(Long userId);

    /**
     * 根据角色ID删除用户角色关联记录
     * @param roleId 角色ID
     */
    void deleteByRoleId(Long roleId);
}
